AMENDMENTS TO THE CLAIMS 



This listing of claims will replace all prior versions, and listings, of claims 
in the application: 

Listing of Claims: 



1 1 . (Original) A method for reducing the overhead involved in 

2 executing native code methods in an application running on a virtual machine, 

3 comprising: 

4 selecting a call to a native code method to be optimized within the virtual 

5 machine; 

6 decompiling at least part of the native code method into an intermediate 

7 representation; 

8 obtaining an intermediate representation associated with the application 

9 running on the virtual machine which interacts with the native code method; 

10 combining the intermediate representation for the native code method with 

1 1 the intermediate representation associated with the application running on the 

12 virtual machine to form a combined intermediate representation; and 

13 generating native code from the combined intermediate representation, 

14 wherein the native code generation process optimizes interactions between the 

15 application running on the virtual machine and the native code method. 

1 2. (Original) The method of claim 1, wherein selecting the call to the 

2 native code method involves selecting the call based upon at least one of: 

3 the execution frequency of the call; and 
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4 the overhead involved in performing the call to the native code method as 

5 compared against the amount of work performed by the native code method. 

1 3. (Original) The method of claim 1, wherein optimizing interactions 

2 between the application running on the virtual machine and the native code 

3 method involves optimizing calls to the native code method by the application. 

1 4. (Original) The method of claim 1, wherein optimizing interactions 

2 between the application running on the virtual machine and the native code 

3 method involves optimizing callbacks by the native code method into the virtual 

4 machine. 

1 5. (Original) The method of claim 4, wherein optimizing callbacks by 

2 the native code method into the virtual machine involves optimizing callbacks that 

3 access heap objects within the virtual machine. 

1 6. (Currently amended) The method of claim 4, 

2 wherein the virtual machine is a platform-independent virtual machine 

3 Java Virtual Machine (JVM) ; and 

4 wherein combining the intermediate representation for the native code 

5 method with the intermediate representation associated with the application 

6 running on the virtual machine involves integrating calls provided by an interface 

7 for accessing native code the Java Native Interface (JNI) into the native code 

8 method. 
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1 7. (Original) The method of claim 1, wherein obtaining the 

2 intermediate representation associated with the application running on the virtual 

3 machine involves recompiling a corresponding portion of the application. 

1 8. (Original) The method of claim 1, wherein obtaining the 

2 intermediate representation associated the application running on the virtual 

3 machine involves accessing a previously generated intermediate representation 

4 associated with the application running on the virtual machine. 

1 9. (Original) The method of claim 1 , wherein prior to decompiling the 

2 native code method, the method further comprises setting up a context for the 

3 decompilation by: 

4 determining a signature of the call to the native code method; and 

5 determining a mapping from arguments of the call to corresponding 

6 locations in a native application binary interface (ABI). 

1 10. (Original) A computer-readable storage medium storing 

2 instructions that when executed by a computer cause the computer to perform a 

3 method for reducing the overhead involved in executing native code methods in 

4 an application running on a virtual machine, the method comprising: 

5 selecting a call to a native code method to be optimized within the virtual 

6 machine; 

7 decompiling at least part of the native code method into an intermediate 

8 representation; 

9 obtaining an intermediate representation associated with the application 
1 0 running on the virtual machine which interacts with the native code method; 
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1 1 combining the intermediate representation for the native code method with 

12 the intermediate representation associated with the application running on the 

13 virtual machine to form a combined intermediate representation; and 

14 generating native code from the combined intermediate representation, 

15 wherein the native code generation process optimizes interactions between the 

1 6 application running on the virtual machine and the native code method. 

1 11. (Original) The computer-readable storage medium of claim 10, 

2 wherein selecting the call to the native code method involves selecting the call 

3 based upon at least one of: 

4 the execution frequency of the call; and 

5 the overhead involved in performing the call to the native code method as 

6 compared against the amount of work performed by the native code method. 

1 12. (Original) The computer-readable storage medium of claim 10, 

2 wherein optimizing interactions between the application running on the virtual 

3 machine and the native code method involves optimizing calls to the native code 

4 method by the application. 

1 13. (Original) The computer-readable storage medium of claim 10, 

2 wherein optimizing interactions between the application running on the virtual 

3 machine and the native code method involves optimizing callbacks by the native 

4 code method into the virtual machine. 

1 14. (Original) The computer-readable storage medium of claim 13, 

2 wherein optimizing callbacks by the native code method into the virtual machine 

3 involves optimizing callbacks that access heap objects within the virtual machine. 



7 

PB Y:\Sun Microsystems\SUNP\SUN-P9042-SPL\Amendment A.doc 



1 15. (Currently amended) The computer-readable storage medium of 

2 claim 13, 

3 wherein the virtual machine is a platform-independent virtual machineJ ava 

4 Virtual Machine (JVM) ; and 

5 wherein combining the intermediate representation for the native code 



6 method with the intermediate representation associated with the application 

7 running on the virtual machine involves integrating calls provided by an interface 

8 for accessing native code the Java Native Interface (JNI) into the native code 

9 method. 



1 16. (Original) The computer-readable storage medium of claim 10, 

2 wherein obtaining the intermediate representation associated with the application 

3 running on the virtual machine involves recompiling a corresponding portion of 

4 the application. 

1 17. (Original) The computer-readable storage medium of claim 10, 



2 wherein obtaining the intermediate representation associated the application 

3 running on the virtual machine involves accessing a previously generated 

4 intermediate representation associated with the application running on the virtual 

5 machine. 



1 18. (Original) The computer-readable storage medium of claim 10, 

2 wherein prior to decompiling the native code method, the method further 

3 comprises setting up a context for the decompilation by: 

4 determining a signature of the call to the native code method; and 
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5 determining a mapping from arguments of the call to corresponding 

6 locations in a native application binary interface (ABI). 

1 19-27. (Cancelled) 

1 28. (Original) A method for reducing the overhead involved in 

2 executing native code methods in an application running on a virtual machine, 

3 comprising: 

4 deciding to optimize a callback by a native code method into the virtual 

5 machine; 

6 decompiling at least part of the native code method into an intermediate 

7 representation; 

8 obtaining an intermediate representation associated with the application 

9 running on the virtual machine which interacts with the native code method; 

1 0 combining the intermediate representation for the native code method with 

1 1 the intermediate representation associated with the application running on the 

12 virtual machine to form a combined intermediate representation; and 

13 generating native code from the combined intermediate representation, 

14 wherein the native code generation process optimizes the callback by the native 

15 code method into the virtual machine. 

1 29. (Original) The method of claim 28, wherein the native code 

2 generation process also optimizes calls to the native code method by the 

3 application. 
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1 30. (Original) The method of claim 28, wherein optimizing the 

2 callback by the native code method into the virtual machine involves optimizing a 

3 callback that accesses a heap object within the virtual machine. 

1 31. (Currently amended) The method of claim 28, 

2 wherein the virtual machine is a platform-independent virtual machineJ ava 

3 Virtual Machine (JVM) ; and 

4 wherein combining the intermediate representation for the native code 



5 method with the intermediate representation associated with the application 

6 running on the virtual machine involves integrating calls provided by an interface 

7 for accessing native code the Java Native Interface (TNI) into the native code 

8 method. 



1 32. (Original) A computer-readable storage medium storing 

2 instructions that when executed by a computer cause the computer to perform a 

3 method for reducing the overhead involved in executing native code methods in 

4 an application running on a virtual machine, the method comprising: 

5 deciding to optimize a callback by a native code method into the virtual 

6 machine; 

7 decompiling at least part of the native code method into an intermediate 

8 representation; 

9 obtaining an intermediate representation associated with the application 

10 running on the virtual machine which interacts with the native code method; 

1 1 combining the intermediate representation for the native code method with 

12 the intermediate representation associated with the application running on the 

13 virtual machine to form a combined intermediate representation; and 
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14 generating native code from the combined intermediate representation, 

1 5 wherein the native code generation process optimizes the callback by the native 

16 code method into the virtual machine. 

1 33. (Original) The computer-readable storage medium of claim 32, 

2 wherein the native code generation process also optimizes calls to the native code 

3 method by the application. 

1 34. (Original) The computer-readable storage medium of claim 32, 

2 wherein optimizing the callback by the native code method into the virtual 

3 machine involves optimizing a callback that accesses a heap object within the 

4 virtual machine. 

1 35. (Currently amended) The computer-readable storage medium of 

2 claim 32, 

3 wherein the virtual machine is a platform-independent virtual machincJ ava 

4 Virtual Machine (JVM) ; and 

5 wherein combining the intermediate representation for the native code 

6 method with the intermediate representation associated with the application 

7 running on the virtual machine involves integrating calls provided by an interface 

8 for accessing native code the Java Native Interface (JNI) into the native code 

9 method. 

1 36-39. (Cancelled) 
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